<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
  </head>
  <body>
    <script>
      Promise.resolve().then(() => {
        console.log("Promise1");
        setTimeout(() => {
          console.log("setTimeout2");
        }, 0);
      });
      setTimeout(() => {
        // 本轮宏任务执行的时候产生的微任务，会在下一个宏任务执行前被清空
        console.log("setTimeout1");
        Promise.resolve().then(() => {
          console.log("Promise2");
        });
      }, 0);
      // 宏任务[s2]
      // 微任务[]

      //  Promise1 setTimeout1 Promise2  setTimeout2
      // 同步代码是在第一次宏任务执行的时候执行，后续会先执行微任务
    </script>
  </body>
</html>
